home *** CD-ROM | disk | FTP | other *** search
Wrap
Text File | 1998-10-24 | 4.6 KB | 152 lines | [ TEXT/ScoM]
g-proportion type start-symbol inst-range operator per-cent1 per-cent2 pattern This function lies somewhere between existing SCOM primitives <symbol-scale> and <symbol-compress>. It has the added attraction of enabling symbol lists or interval series to be used as source material for the generation of new material 'in proportion' to the source. The function parameters allow for a wide range of possibilities: type - nil = list or sublist type - :list :constant :consecutive = sublist start-symbol = nil, integer, symbol, pitch, list inst-range = low high (symbol, integer, pitch), or instrument-name operator = >, <, <>, >< per-cent = integer1 integer2 pattern = symbols, intervals TYPE: exp. nil ( . . . . . . . . . ) ; symbols ( 50 38 25 12 0 -12 -25 -38 -50 ) ; '> 50 -50 exp. nil (( . . . ) ( . . . ) ( . . . )) ; symbols ( 50 38 25 12 0 -12 -25 -38 -50 ) ; '> 50 -50 exp. nil ( . . . . . . . . . ) ; symbols ( 35 35 35 35 35 35 35 35 35 ) ; '> 35 35 exp. :list (( . . . ) ( . . . ) ( . . . )) ; symbols (( 50 50 50 ) ( 0 0 0 ) ( -50 -50 -50 )) ; '> 50 -50 exp. :constant (( . . . ) ( . . . ) ( . . . )) ; symbols (( 50 0 -50 ) ( 50 0 -50 ) ( 50 0 -50 )) ; '> 50 -50 exp. :consecutive (( . . . ) ( . . . ) ( . . . )) ; symbols (( 50 38 25 ) ( 12 0 -12 ) ( -25 -38 -50 )) ; '> 50 -50 The scope of this particular function is best described through a series of examples, as below. INTERVAL: (setq op.31-Var-für-Orch '(1 7 9 6 8 0 5 4 10 11 2 3)) (setq interval-list (get-interval :all op.31-Var-für-Orch)) => (6 2 -3 2 -8 5 -1 6 1 -9 1) (g-proportion nil 1 -5 45 '> 50 -50 interval-list) => (b k n k n f k k p q l l) (g-proportion nil 1 -5 45 '> 50 50 interval-list) => (b k n i l -b g e n o a b) (g-proportion nil 'c#4 'viola '<> -30 70 interval-list) => (b g i f i -e e d m o f g) (setq interval-rotate (rotate-fc 2 interval-list)) => ((6 2 -3 2 -8 5 -1 6 1 -9 1) (2 -3 2 -8 5 -1 6 1 -9 1 6) (-3 2 -8 5 -1 6 1 -9 1 6 2)) (setq interval-lists (g-chord .25 1 2 0 0 interval-rotate)) => (((6 2) -3 (2 -8) (5 -1) 6 (1 -9) 1) (2 -3 (2 -8) (5 -1) 6 (1 -9) (1 6)) (-3 2 -8 (5 -1) (6 1) -9 (1 6) 2)) (g-proportion nil 1 -5 45 '<> -45 70 interval-lists) => ((b fh f hb gg n pf h) (k g j-d gf q se gp) (l o f lk qr k lq s)) (g-proportion :list 1 -5 45 '<> -45 70 interval-lists) => ((b fh g ie hh l mi j) (n i m-b hg r te gr) (m q d lk vx i kv z)) (g-proportion :constant 1 -5 45 '<> -45 70 interval-lists) => ((b fh e h-e ed m of g) (i g ja ih s uj lq) (p r j qp [] p ry [)) (g-proportion :consecutive 1 -5 45 '<> -45 70 interval-lists) => ((b fh f hb gg n pf h) (k g j-d gf q se gp) (l o f lk qr k lq s)) (g-proportion :consecutive '(0 1 2) -5 45 '<> -45 70 interval-lists) => ((a eg e ga ff m oe g) (b e a dp yx \c \eW |Yb|) (c -c b k qp vw p qv x)) SYMBOL: (setq op.37-4.StrQu '(5 4 0 1 8 6 7 3 11 10 9 2)) (setq symbol-list (i-process 5 'violin (get-interval :all op.37-4.StrQu))) => (f e a b i g h d l k j c) (g-proportion nil 5 -5 45 '> 50 -50 symbol-list) => (f d -c a j h i f m m m i) (g-proportion nil 'f -5 45 '> 50 50 symbol-list) => (f d -d -c i f g a m k i -d) (g-proportion nil 'f4 'viola '<> -30 70 symbol-list) => (f f c e o l n h t s r l) (setq symbol-rotate (rotate-fc 2 symbol-list)) => ((f e a b i g h d l k j c) (e a b i g h d l k j c f) (a b i g h d l k j c f e)) (setq symbol-lists (g-chord .25 1 2 0 0 symbol-rotate)) => ((fe ab i gh dl k jc) (e a b ig hd l kj cf) (a b i g hd lk j cf e)) (g-proportion nil nil -5 45 '<> -45 70 symbol-lists) => ((ff de k jk hq p og) (j e g qn pj x wv kp) (j l u s uq yy y tw w)) (g-proportion nil 'd#4 -5 45 '<> -45 70 symbol-lists) => ((dd bc i hi fo n me) (h c e ol nh v ut in) (h j s q so ww w ru u)) (g-proportion :list nil -5 45 '<> -45 70 symbol-lists) => ((ff de i hi gl l li) (e -c a mj lf t sr gm) (a c o l nh vu t io n)) (g-proportion :list 0 -5 45 '<> -45 70 symbol-lists) => ((aa -c-b d cd bg g gd) (-b f h tq sm [ zy nt) (-f -d j g ic qp o dj i)) (g-proportion :constant '0 -5 45 '<> -45 70 symbol-lists) => ((aa -d-b i gi co n mh) (-b -d -c ge ga o nm fi) (-f -e c a c-d lk j bf f)) (g-proportion :consecutive 0 -5 45 '<> -45 70 symbol-lists) => ((aa -c-b f ef cl k jb) (-b e g ro qk y xw mr) (-f -d g e gc kk k fi i)) (g-proportion :consecutive '(0 1 2) -5 45 '<> -45 70 symbol-lists) => ((aa -c-b f ef cl k jb) (b -e -c jg ic q po ej) (c e n l nj rr r mp p))